In re COHEN ET AL., Application No. 10/812,207 
Amendment B 



Amendments to the Claims: 

The listing of claims will replace all prior versions, and listings, of claims in the application: 
Listing of Claims: 

Claim 1 (previously presented): A method for reassembling a packet, the packet when 
reassembled includes a plurality of packet fragments with each packet fragment identified 
with a position within the packet, the method comprising: 

maintaining a plurality of queues; 

enqueuing the plurality of packet fragments in a plurality of the plurality of queues, 

and 

retrieving the plurality of packet fragments from the plurality of packet queues based 
on indications added to a data structure identifying the order of the plurality of packet 
fragments to produce the packet; 

wherein said operation of enqueuing the plurality of packet fragments in the plurality 
of the plurality of queues includes, for each particular packet fragment of the plurality of 
packet fragments: identifying a particular queue of the plurality of queues such that no already 
queued packet fragment of the packet in the particular queue comes after the particular packet 
fragment in the packet, wherein said identifying the particular queue for the particular packet 
fragment includes checking, at least when the particular queue is not empty, that the particular 
queue does not include a packet fragment which comes after the particular packet fragment in 
the packet; enqueuing the particular packet fragment at the end of the particular queue; and 
updating the data structure to include an indication of the particular queue in relation to the 
position of the particular packet fragment in the packet. 

Claim 2 (original): The method of claim 1, wherein said retrieving the plurality of 
packet fragments is performed in response to identifying that all of the plurality of packet 
fragments have been enqueued in the plurality of queues. 
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Claim 3 (previously presented): The method of claim 1, wherein said operation of 
enqueuing the plurality of packet fragments in the plurality of the plurality of queues includes 
identifying that no queue in the plurality of queues does not already have enqueued a packet 
fragment which comes after the particular packet fragment in the packet, and in response, 
expanding the plurality of queues by adding a queue to the plurality of queues. 

Claim 4 (previously presented): The method of claim 3, including reducing the number 
of queues in the plurality of queues in response to identifying that a queue is empty. 

Claims 5-6 (canceled) 

Claim 7 (original): The method of claim 1, wherein the data structure corresponds to a 
meta-packet or scorecard including the indications of the queues of the plurality of queues 
maintained in an order corresponding to the positions of their corresponding packet fragments 
within the packet. 

Claim 8 (original): The method of claim 1, wherein at least two packet fragments of 
the packet are enqueued in a same queue of the plurality of queues. 
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Claim 9 (original): A method for resequencing packets, the method comprising: 

maintaining a plurality of queues of a resequencing mechanism; 

receiving a particular packet of a stream of packets, each packet of the stream of 
packets identifying a sequence number of an ordered sequence of sequence numbers, the 
particular packet including a particular sequence number; 

identifying a particular queue of the plurality of queues such that no packet in the 
particular queue includes a sequence number subsequent to the particular sequence number in 
the ordered sequence, wherein said identifying the particular queue includes checking that the 
particular queue does not include a packet with a sequence number subsequent to the 
particular sequence number in the ordered sequence; 

enqueuing the particular packet at the end of the particular queue; and 

retrieving packets in sequence from the plurality of queues. 

Claim 10 (original): The method of claim 9, including identifying that no queue in the 
plurality of queues does not include a packet with a sequence number subsequent to the 
particular sequence number in the ordered sequence, and in response, expanding the plurality 
of queues by adding the particular queue to the plurality of queues; and wherein said 
identifying the particular queue includes said checking operation when the particular queue is 
not empty. 

Claim 1 1 (original): The method of claim 10, including reducing the number of queues 
in the plurality of queues in response to identifying that the particular queue is empty. 

Claim 12 (original): The method of claim 1 1 , wherein said reducing the number of 
queues includes removing the particular queue from the plurality of queues. 
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Claim 13 (previously presented): An apparatus for reassembly of a packet, the packet 
when reassembled includes a plurality of packet fragments with each packet fragment 
identified with a position within the packet, the apparatus comprising: 

a plurality of reassembly queues; 

a reassembly mechanism; and 

a distributor configured for each particular packet fragment of the plurality of packet 
fragments: to acquire the particular packet fragment of the plurality of packet fragments, to 
identify a particular queue of the plurality of reassembly queues such that no already queued 
packet fragment in the particular queue comes after said particular packet fragment in the 
packet; to cause said particular packet fragment to be enqueued at the end of the particular 
queue; and to update a data structure to include an indication of the particular queue in 
relation to the position of said particular packet fragment in the packet; wherein said 
identifying the particular queue includes checking, at least when the particular queue is not 
empty, that the particular queue does not include a packet fragment which comes after said 
particular packet fragment in the packet; and wherein at least a plurality of said reassembly 
queues contains one or more of the plurality of packet fragments; and wherein the distributor 
is configured to identify when all packet fragments of the packet have been received and in 
response, to provide the reassembly mechanism with indications of the queues of the plurality 
of reassembly queues containing packet fragments of the packet and their order corresponding 
to that of the order of the plurality of packet fragments in the packet; and 

wherein the reassembly mechanism is configured to retrieve the plurality of packet 
fragments from the plurality of resequencing queues based on the indications added to the data 
structure and reassemble the plurality of packet fragments to produce the packet. 

Claim 14 (original): The apparatus of claim 13, wherein the reassembly mechanism is 
configured to retrieve the plurality of packet fragments from the plurality of resequencing 
queues in their respective order within the packet. 
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Claim 15 (previously presented): The apparatus of claim 13, wherein the distributor is 
configured to communicate a meta-packet or scorecard including said indications of the 
queues to the reassembly mechanism. 

Claim 16 (original): The apparatus of claim 13, wherein the distributor is configured to 
identify that every queue in the plurality of queues already includes a packet fragment 
corresponding to subsequent position in the packet and in response, causing the plurality of 
queues to expand in number by adding the particular queue to the plurality of queues. 

Claim 17 (previously presented): The apparatus of claim 16, wherein the apparatus is 
configured to reduce the number of queues in the plurality of queues in response to identifying 
that the particular queue is empty. 

Claim 18 (canceled) 

Claim 19 (original): The apparatus of claim 13, wherein the distributor identifies a 
same particular queue of the plurality of reassembly queues for at least two of the plurality of 

packet fragments. 
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Claim 20 (original): A method for resequencing and reassembling of packets, the 
method comprising: 

maintaining a plurality of queues; 

acquiring a packet fragment of a plurality of packet fragments of a packet, wherein a 
stream of a plurality of packets includes the packet; 

identifying a particular queue of the plurality of queues for the particular packet 
fragment such that no already queued packet fragment in the particular queue comes after the 
particular packet fragment in the packet and the particular queue includes no already queued 
packet fragment of a packet subsequent to the particular packet in the stream of packets; 
wherein said identifying the particular queue includes checking, at least when the particular 
queue is not empty, that the particular queue does not include a packet fragment which comes 
after the particular packet fragment in the packet or the stream of packets; enqueuing the 
particular packet fragment at the end of the particular queue; and updating a data structure to 
include an indication of the particular queue in relation to the position of the particular packet 
fragment in the packet and the stream of packets; and 

retrieving the plurality of packet fragments from the plurality of packet queues based 
on the data structure to produce the packet. 

Claim 21 (original): The method of claim 20, wherein said retrieving the plurality of 
packet fragments is performed in response to identifying that all of the plurality of packet 
fragments have been enqueued in the plurality of queues and no other packet prior to the 
packet in the stream of packets is enqueued in the plurality of queues. 
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Claim 22 (original): The method of claim 20, including identifying that no queue in 
the plurality of queues does not already have enqueued a packet fragment in the particular 
queue which comes after the particular packet fragment in the packet or a packet fragment of a 
packet subsequent to the packet, and in response, expanding the plurality of queues by adding 
the particular queue to the plurality of queues. 

Claim 23 (original): The method of claim 22, including reducing the number of queues 
in the plurality of queues in response to identifying that the particular queue is empty. 

Claim 24 (original): The method of claim 23, wherein said reducing the number of 
queues includes removing the particular queue from the plurality of queues. 

Claim 25 (original): The method of claim 20, wherein the plurality of packet fragments 
are retrieved from the plurality of queues in order of their respective position within the 
packet and the order of the packet within the steam of packets. 

Claim 26 (original): The method of claim 20, wherein the data structure corresponds to 
a meta-packet or scorecard including the indications of the queues of the plurality of queues 
maintained in an order corresponding to the positions of their corresponding packet fragments 
within the packet. 



Claim 27 (original): The method of claim 20, wherein at least two packet fragments of 
the packet are enqueued in a same queue of the plurality of queues. 



